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INPUTJPORT(l) register float *Prepower; 
INPUT_PORT(2) register float *Postpower; 
INPUT_PORT(3) register float *RFgain; 

OUTPUT_PORT(l) register float *Output; I*W AGC Gain in dB*/ 
BLOCKFACTOR long BlockFactor; 

PARAMETER(l) float OutputlntervalWidth; /* 71 dB*/ 
PARAMETER^) float SetPointdBPre; /*42.2*/ 
PARAMETER(3) float SetPointdBPost; /*32.2*/ 
PARAMETER(4) float Kagc; /*0.25*/ 
PARAMETER(5) float PreDropdB; /* 3.0*/ 

PARAMETER^) long WaitTime; /*8 OFDM Frames! !*/ 

STATE float oldoutput; 
STATE float oldrfgain; 
STATE long counter; 

#include <math.h> 

void init ofdmagccontrol2() 
{ 

/* initialize Sum */ 
oldoutput = 0.0; 
counter = WaitTime; 

} 

void ofdmagccontrol2() 
{ 

register float dbinpre, dbinpost, err, rfgam, output; 
float Halflnterval = (OutputlntervalWidth / 2.0); 
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LOOP(BlockFactor) 

printf(" -IFbeg An"); 

dbinpre = *Prepower++; dbinpost = *Postpower++; 
rfgain = *RFgain++; 

printf("prepower = %f, post = %f, rfgain = %f\n", dbinpre, dbinpost, rfgain); 
if((rfgain-oldrfgain) !=0.0) 

{ 

output = oldoutput -(rfgain-oldrfgain); 

printf("ifgain = -rfdiff = %f, oldrfgain = %f\n", output, oldrfgain); 

else if ((SetPointdBPre-PreDropdB-dbinpre <=0.0)&& (counter >= WaitTime)) 
{ 

output = oldoutput -(PreDropdB+2.0); 
printf( M ifgain = due to Pre = %f\n", -PreDropdB); 
counter=0; 
} 

else 

{ 

counter++; 

if(SetPointdBPre-dbinpre < SetPointdBPost-dbinpost) 
err = SetPointdBPre - dbinpre; 

else 

err = SetPointdBPost-dbinpost; 
err = Kagc*err; 
output = oldoutput+err; 
printf("output = %M\ output); 

} 

if(output>=HalfInterval) 

output = Halflnterval; 
else if (output<=-HalfInterval) 

output = -Halflnterval; 

else 

output = output; 

*Output++ = output; 
oldrfgain = rfgain; 
oldoutput = output; 

printfC IFend \n"); 

ENDLOOP 

} 
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